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Transactions carried out using a communications network are facilitated by systems and methods which enable representatives of 
a marketing party to initiate private, one-on-one communications with potential buyers. When a potential buyer expresses an interest in 
particular goods or services by logging onto a web site a unique identifier can be assigned to that visitor. A representative can be alerted 
to the presence of the visitor. Being aware of the visitor enables the representative to initiate interactive communications with the visitor. 
The progress of the visitor through the pages of the site can be tracked to assess the effectiveness of the site. 
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SYSTEM ENABLING A SALESPERSON TO CHAT WITH A CUSTOMER BROWSING THE 
SALESPERSON'S WEBSITE 
5 Related Ap plication 

This application is a continuation-in-part of provisional application 

Serial No. 60/061,166 , filed October 6, 1997. 
ffjpiH nf the Invention: 

The invention pertains to systems and methods for facilitating 
10 interactions on communications networks. More particularly, the invention pertains 
to such systems and methods usable to provide interactive real time communications 
between a user and another parry while the user is viewing a page or pages of a 
web site. 

Back ground <*f the Invention : 

15 a service of the Internet, the Worldwide Web, has evolved as a 

readily available source of worldwide information. In addition to merely providing 
information, numerous companies have established web sites through which are 
offered a variety of goods and services. 

A visitor perusing a page or pages of a selected site selects those 

20 goods or services of interest and arranges to . pay for them using a credit or debit 
card for example. While there has been great interest in this form of electronic 
commerce and many companies have established web sites for the purposes of 
marketing their products and services, some limitations have been encountered. 

One limitation that has been encountered has been an inability of 

25 visitors, who have expressed an interest in the products or services by their 
presence at the site to easily obtain answers to questions about the products or 
services. Another limitation that has been noted is an inability of the organization 
whose web site is being viewed to monitor the progress of the user and to initiate 
communication, substantially in real time, with the user during the viewing session. 

30 In known systems, it has been necessary for the site visitor or 

potential customer to initiate an interaction. Not all visitors take this step. 
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Another form of known, interactive, network based communications 
is the so-called chat room. Chat rooms enable individuals having a common 
interest to interact substantially in real time concerning any subject that might be 
of interest to them. While facilitating interactive communications, chat rooms have 
5 not as yet had a substantial effect on web based commerce. One reason for this 
may be that persons visiting chat rooms may not have any interest at that time in 
buying goods or services of a type associated with the chat room. A second reason 
may be that chat rooms are multi-person forums that do not readily lend themselves 
to 1:1 interactions. Another reason is that a user must take steps to join a chat 

10 room in order to participate. A monitoring party could not bring a visitor into a 
chat room to initiate an interaction. 

There thus continues to be a need for interactive communications 
capabilities which can be used to facilitate web based commerce. It would be 
desirable to enable a site representative to proactively engage a visitor. It would 

15 also be desirable if such capabilities could be incorporated into web sites or pages 
which offer goods or services. In a preferred system, it will not be necessary to 
download to the user any applets, "cookies", software modules or the like. 
Preferably, such interactive communications could be implemented using, at the 
user's site, nothing more than a standard commercial browser such as those 

20 available from Microsoft Corporation or Netscape. 
Summary of the Invention : 

The presence of a visitor at a web site that offers goods or services 
is an indication that the visitor is interested enough in the goods or services to be 
a potential customer. This is a self-screening process. In effect, the visitor's 

25 presence is a statement of interest in the subject goods or services. 

The visitor's presence at a given commercial site is also a statement 
that "this is a good time" to consider obtaining the offered goods or services. In 
accordance with the present invention, a representative of a web site is provided 
with the tools to proactively contact a visitor in an appropriate business-like fashion 

30 to open an interactive dialog to offer to assist or help the visitor by answering 
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questions or offering suggestions. The dialog can be carried out interactively in 
real-time. 

The proactive capability is analogous to having a knowledgeable sales 
person approach and initiate a dialog with a potential customer in a store. 
5 Questions can be answered and additional suggestions can be made to the customer 
in real-time. 

Systems and methods for facilitating electronic commerce make it 
possible for a visitor who has access to a web site to review the pages of that web 
site. While reviewing the pages, the visitor can be contacted by a representative 

10 of the proprietor of the site for purposes of initiating an interactive interchange, a 
conversation, with that visitor. The present systems and methods make use of the 
frame-based functionality of the visitor's browser. No applets, cookies, modules 
or other software need to be downloaded to the visitor's computer. 

In another aspect, the visitor's movement through the pages of the 

15 site can be tracked and recorded. The list of tracking information for respective 
visitors can be stored for later review and follow-up. The tracking information can 
be presented in real time to the representative to facilitate the communications 
process. 

In yet another aspect, a dialogue box can be opened on the visitor's 
20 display for purposes of initiating a text-based interactive conversation. At the 
initiating end of the conversation, a display can be provided of both sides of the 
conversation. 

Alternatively, a graphical symbol or icon can be provided on the 
visitor's display. Triggering or clicking on the symbol or icon enables the visitor 
25 to open a conversation with a representative of the site. The representative can 
then respond to the visitor's inquiries on a real time basis. Specific questions can 
be answered and any concerns raised by the visitor about the goods or the services 
can be addressed immediately. 

In yet another aspect, the present systems and methods can be 
30 implemented with respect to web sites that use HTML coded pages. This 
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implementation, which makes use of HTML frame tags supported by currently 
available browsers, is especially desirable. Only the pages associated with a 
selected web site need be supplemented with additional frame and link tags. No 
applets, "cookies" or other modules need be downloaded to the visitor's computer. 
5 All that is required at the visitor's end is that the respective browser be capable of 
responding to frame tags. 

In yet another aspect, where a visitor logs onto a web site a unique 
identifier is assigned to that visitor. This identifier can be used to track the 
progress of the visitor through the pages of the site. Unlike an IP address which 
10 can be associated simultaneously with a plurality of visitors to the site, the unique 
assigned identifier enables a representative of the site to initiate a 1:1 interactive 
conversation with the visitor. 

The unique identifier also enables a web site proprietor to analyze 
either in rea time t or, off line patterns of usage of the site. High traffic, 
15 commercially effective paths can be identified and emphasized. Low traffic paths 
can be revised or discontinued. 

Exemplary applications of the invention include: 

• Providing a live sales person in the internet. 

Example: A jewelry sales web site, where the site is organized to 
20 lead the visitor to one of a number of product categories (for example, rings, 
watches, necklaces, etc.). Sales oriented representatives watch the visitors move 
through the site. Once a visitor lingers on a product page for more than 3 minutes, 
a representative engages that visitor and offers assistance. If the visitor responds 
favorably, the representative attempts to close a sale. If the visitor requests to be 
25 left alone, the representative terminates the conversation. 

• Matching a user who has a specific question with an expert 
representative. 

Example: A technical support web site, where the site is organized 
to lead the visitor through a series of choices defining the nature of the visitor's 
30 problem before presenting a button encouraging the visitor to "Click here to speak 
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to a live support representative". When the visitor clicks on the button, a pool of 
support representatives is notified of the contact request. Each representative views 
the visitor's page history to determine the nature of the problem, and the 
representative most familiar with the problem engages the visitor. The 
5 representative and the visitor hold a text-based conversation regarding the problem, 
and once it is solved, the Representative terminates the conversation. 

• Matching the correct regional sales agent with the correct 
customer. 

Example: A property rental web site monitored by three pools of 
10 representatives, each with a geographic area to service. The web side is organized 
by location (North, Central, and South) and each area is subdivided by property 
type (house, apartment, office). Each representative monitors only the portion of 
the web site which corresponds to their geographic region. As the visitor moves 
throughout the pages on the site, the appropriate representative is able to watch the 
15 visitor's page selections and engage that visitor already knowing that the visitor 
wants, for example, a 3-bedroom apartment in the Central region. 

• Correct and validate the customer choices in a user- 
configurable product order system. 

Example: A computer sales web site where web visitors configure 
20 the system they wish to purchase. The visitor selects the components they want, 
then submits the list to a validation program. If the validation program categorizes 
the system as poorly designed, a representative notified and engages the visitor in 
a conversation to talk them through and correct their choices. 

Numerous other advantages and features of the present invention will 
25 become readily apparent from the following detailed description of the invention 
and the embodiments thereof, from the claims and from the accompanying 
drawings. 

Detailed Description of the Preferred Embodiments : 

While this invention is susceptible of embodiment in many different 
30 forms, there are shown in the drawing and will be described herein in detail 
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specific embodiments thereof with the understanding that the present disclosure is 
to be considered as an exemplification of the principles of the invention and is not 
intended to limit the invention to the specific embodiments illustrated. 
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Exemplary iContact Implementation 

Requirements 

1 When clients (visitors) log into the web site, their Financial Consultant (FC) is notified that they are on the site. 
2. Clients (visitors) can determine whether or not their FC is monitoring the web site and available to assist them. 

Solutions for Meeting Requirements 
Requirement 1 

The following steps show how iContact can determine the Visitor's FC and notify the FC that one of their clients is 
presently on the web site. Please refer to Diagram 1 while reviewing the following steps. 

(1) When a web visitor first accesses the web site they are registered into iContact. iContact returns a frame set to 
the visitor's browser that will stay with the visitor during their visit. The frame set allows iContact to track and 
identify the visitor. Since they have yet to login to the web site, and be identified, they are not displayed on any 
of the FCs workstations. 

(2) The visitor logs into the web site. Upon successfully logging into the system, a page associated with the visitor's 
FC, in this case M. Owens, is returned to the visitor's browser. 

(3) The returned page immediately requests a page from the iContact server. The requested page's title is the 
iContact system identifier assigned to the FC when their account was created, in this case "mowens" (actual 
identifier is numeric). 

(4) The page request notifies the iContact system that this visitor has requested a page with the tide of "mowens". 
The page is returned to the visitor's browser and the request is passed on to the NetRep client applications 
installed on the FCs workstations. 

(5) The visitor's iContact assigned system identifier (25736) and the title of the page they requested (Wens'') is 
sent to all the FCs logged into the system. Each client application will determine if they are allowed to monitor 
this individual. This is done by checking if the page title (a.k.a. FCs system identifier) is in their filter list or the 
visitor's identifier is in their active list. 

(6) In this case the page title is in M Owens' filter list, so the visitor will now appear in his NetRep client 
application's Visitor List. M. Owens can also be notified by any combination of audible and visual indicators 
generated by the NetRep client application. At this point, M. Owens has the option to proceed and engage the 
visitor and starting the conversation via iContact. 

(7) The visitor can continue surfing through the web site normally. M. Owens will not be aware of which page they 
are viewing, only that they are still on the site. 

(8) If it is determined that knowing the specific page (or section of the web site) the visitor is viewing is necessary 
m ta k request for the specific page (or first page of the section) will be made through ^ ^Contact. iContact will 

return the requested page to the visitor's browser and pass the request on to the NetRep client applications. 

(9) The visitor's system assigned identifier (25736) and the tide of the page they requested ("quotes") is sent to a. 
{) *e FC ^ logged into me system- Each client application will determine if they are allowed to ^monitor 

individual. They do this by checking if the page title (a.lca. FCs system identifier) is in their filter list or the 
visitor's identifier is in their active list. 

(10) In this case the visitor's identifier is in M. Owens' active list, so the entry in M. Owens' Visitor List will be 
updated. M. Owens can also be notified by any combination of audible andvisual indicators generated by the 
NetRep client application if this new page is in his page notification list. 



Requirement 2 

The following steps show how visitors can determine whether their FC is monitoring the site and ava.lable to assist 
them. Please refer to Diagrams 2A'& 2B while review the following steps. 
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Contacting their registered FC Diagram 2A 

(1) The visitor decides they want to communicate with their FC using iContact. They click a "Contact a Financial 
Consultant" link which displays a list of available FCs. The link can be distributed throughout the web site. The 
list will contain all the FCs registered to use iContact or it can also include unregistered FCs with a list of 
alternative contact methods like telephone number, email, or an automatic call back form. 

(2) The visitor selects his/her FC from the list and clicks their name, in this case "M Owens". 

(3) This sends a request to the iContact system for M. Owens. The request consists of the visitors unique identifier, 
the FCs identifier, and the URL of a page with the tide of "mowens". 

(4) iContact checks to see if the requested FC, "mowens", is logged into the system by checking the NetRep status 
list on the iContact server. 

(5) If M. Owens is logged into the system, then a page requesting the visitor to "Please Wait for Contact" will be 
returned to the visitor's browser. Otherwise a message stating that the requested FC is not available will be 
returned. Alternate methods of contact can also be displayed at this time. 

(6) If M. Owens is logged into the system, the visitor's iContact assigned system identifier (25736) and the title of 
the page they requested ("mowens") is sent to ail the FCs logged into the system Each client application will 
determine if they are allowed to monitor this individual. This is done by checking if the page title (a.k.a. FCs 
system identifier) is in their filter list or the visitor's identifier is in their active list. 

(7) In this case the page title is in M. Owens' filter list and the system identifier is in his Active List. The visitor's 
entry in M. Owens' Visitor List will change its state from "Available" to "HI" designating that they have 
requested contact. M. Owens can also be notified by any combinarion of audible and visual indicators generated 
by the NetRep client application. 



Contacting another registered FC Diagram 2B 

(1) The visitor decides they want to communicate with another FC if theirs is not available. They click a "Contact a 
Financial Consultant" link which displays a list of available FCs. The link can be distributed throughout the web 
site. The list will contain all the FCs registered to use iContact or it can also include unregistered FCs with a list 
of alternative contact methods like telephone number, email, or an automatic call back form. 

(2) The visitor selects a FC from the list and clicks their na.*ie, in this case "R. Lincoln". 

(3) This sends a request to the iContact system for R. Lincoln. The request consists of the visitors unique identifier, 
the FCs identifier, and the URL a page with the title of "rlincoln". 

(4) iContact checks to see if the requested FC, "rlincoln", is logged into the system by checking the NetRep status 
list on the iContact server 

(5) If R Lincoln is logged into the system, then a page requesting the visitor to "Please Wait for Contact" will be 
returned to the visitor's browser. Otherwise a message stating that the requested FC is not available will be 
returned. Alternate methods of contact can also be displayed at this time. 

(6) If R. Lincoln is logged into the system, the visitor's iContact assigned system identifier (25736) and the title of 
the page they requested ("riincoln") is sent to all the FCs logged into the system. Each client application will 
determine if they are allowed to monitor this individual. This is done by checking if the page title (a.k.a. FCs 
system identifier) is in their filter list or the visitor's identifier is in their active list. 

(7) In this case the page title is in R. Lincoln's filter list, so the visitor will now appear in his NetRep client 
application's Visitor List with if s state set to "HI" designating that they have requested contact. 

(8) In this case the system identifier is in M. Owens' Active List. The visitor's entry in M. Owens' Visitor List will 
change its state from "Available" to "HI" designating that they have requested contact 
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Method for distinguishing individual Surfers on an Internet site 

As Surfers flow into an iContact enabled web site, the software automatically assigns a 
unique identifier to each visitor. As with most of the claims we are discussing, I believe 
that this is reliant on our ability to track and provide functionality without visitor 
instigation or the possibility of their interference (i.e. turn off "cookies", Java, or refuse to 
fill out a form). 

First, because many Surfers dial-up through large proxy servers, a large number of 
visitors are identified by the same IP address. For example, normal server logs will list all 
activity from AOL users in New York as essentially the function of the same user. Given 
that we need to distinguish between all individuals on an Internet site in order to enable 
one-on-one communication, we created a method to monitor in real-time the activities of 
each individual visitor to a site. By sending a periodic request to the web server 
("heartbeat"), iContact allows live representatives to visually monitor each individual 
visitor's activity without concern for shared EP addresses. 

There are other ways to attempt to distinguish individual visitors, however, iContact is 
unique because it does not require a Surfer to accept a downloaded piece of data or 
perform a user-initiated function. For example, if every visitor is asked to fill out a form 
or provide a usemame and password, the server can then distinguish between all Surfers. 
Internet "cookies" can aiso be sent to each individual to allow the web server to monitor 
individual activities. The iContact software is unique in that visitors are not required to 
accept cookies (which is at a Surfer's discretion), fill out any type of registration or form, 
or perform any action beyond requesting an HTML page from a web server. It should be 
noted that iContact does not preclude the use of cookies, forms or logins; it just does not 
require them. 

Technically, this all takes place during steps 1 and 4 on DJ's Diagram One. I laid out 
instructions for six sample pages below that can be used to provide an example of what 
DJ was referring to. The pages will show a progression in HTML as a Surfer sees them: 
first as they arrive, then when they have a unique ID attached, and finally when a 
conversation has begun. 
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Figures 1-1 through 1-3 
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Figwre V-Aa - New, uncultured (unregistered) visitor to the site. 
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Figure l-lb - NetRep Client with no visible (registered) surfers. 
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Company 
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developed in a vanety of industries. From software to web sites, and from 
marketing and advertising. Contact Dynamics bongs to bear a variety of 
resources in order deliver resurts, instead of naw questions. Wo recognize 
that our clients are not seeking the newest software, but instead are 
searching for an overall plan that wiU finally help deliver on the financial 
promise of the web. 
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owners the opportunity to communicate with their "Visitors" Although a 
significant portion of our efforts are spent developing and maintaining a 
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variety of other services (underlines are clickable links to those pages) 
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Figure I -2b NetRep Client with uncaptured, but registered surfer. 
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promise of me web 

The original tmoetus for designing the (Contact software was to offer web site 
owners We opportunity to communicate w«n their 'wsitors* Although a 
significant portion of our efforts are soent developing and maintatnng a 
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Figure J-3a 


- Conversation frameset with captured surfer. 
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F/gwre NetRep Client engaged in a conversation with a surfer. 
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Display system for live NetReps that rationally exhibits current traffic 
activity of an Internet site 

The essential claim here is simple. Given that no one has ventured to proactively 
approach Surfers, no one has yet developed a system that organizes web activity into a 
"control panel" which allows NetReps to watch and dynamically communicate with 
Surfers. We have collected all the information that we can in real-time, and have built a 
graphical user interface (GUI) that provides NetReps with valuable tracking information 
about visitors before, during, and following communications. Although there are literally 
hundreds of reasons and uses for this GUI, we sought in the design to enable three basic 
functions. 

/ ) Enable live NetReps to approach visitors based upon observed behaviors 

This is perhaps the most important function of the GUI. In the same way that a good 
vantagepoint allows a retailer to gauge their store's activity, iContact provides a web site 
owner with a clear view of their virtual business. Live NetReps can visually monitor each 
visitor's current location, the amount of time each has spent on that page and the site in 
total, and a list of the last ten pages that each visiter has viewed. By providing businesses 
with'this information they can proactively approach any number of visitors in order to 
react to or capitalize on observed Surfer behavior. The analogy is simple: retailers have 
always watched their stores and approached people based on what they did once they got 
inside. They ask the person wandering aimlessly if they can help them find something, 
and they approach people when they pause to examine an item in order to spurn the sales 
process. The iContact software translates server information into a GUI that allows 
businesses to provide the same dynamic sales and service assistance to their Internet 
visitors. 

The simplest example involves a NetRep monitoring the transaction area of a site. In 
order to complete a purchase, most web sites first ask Surfers to fill out a torm with all ot 
their personal and pavment information. The Surfer then submits this form and waits until 
the transaction is cleared or rejected. Live NetReps could watch the transaction area and 
approach Surfers who either aborted the transaction or who were sent to the denial page. 
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Figures 2-1 through 2-6 
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Figure 2-1 - NetRep Client with four uncaptured visitors. Two are on the purchase page, 
two are elsewhere on the site. 
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Figure 2-2- Surfer on the Ordering section of the site. 
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Figure 2-5 - NetRep Client with the same uncaptured visitors. One visitor's order has 
been denied while the other's has been accepted. 
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Figure 2-4 - The Surfer's screen after his/her order was denied. 
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/^w* 2-5 - The surfer is engaged by a NetRep who notices that the surfer's order has 
been denied. The conversation frameset appears. 
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F/gure 2-6 - NetRep Client now with three uncaptured visitors. The engaged visitor is 
the surfer whose order was denied. 
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NetReps could also approach Surfers who appear lost. If a NetRep observes a Surfer 
quickly moving through multiple pages without spending the time to stop and examine 
any content, they can assume that the visitor has not located the desired information. The 
software then enables a NetRep to approach that Surfer with the same type of polite 
assistance that is offered in retail environments: "Hello, I noticed that you appeared a 
little lost, can I help you find something specific". 



Figures 3-1 through 3-6 
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Figure 3-1 - NetRep Client with three uncaptured visitors. Two are on the catalog page, 
the other is elsewhere on the site. 
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F/^wre i-2 - NetRep Client with same uncaptured visitors. One of the visitors previously 
on the catalog page has now moved to the employment page. 
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Figure 3-3 - NetRep Client with same uncaptured visitors. The visitor previously on the 
employment page has now moved to the main page. 
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/wgwre 5-4 - NetRep Client with same uncaptured visitors. The visitor previously on the 
main page has now moved to the site map page. 
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Figure 5-J - The observant NetRep now captures the aforementioned surfer. He/she 
offers to help with navigation. 
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F/gwre J-o~ - The engaged surfer tells the NetRep that he/she is looking for the Order 
Page. The NetRep sends a link in the conversation frameset that points to the order form. 



2) Provide a system and GUI that gathers the information needed to prioritize and 
logically direct NetReps to approach and respond to individual Surfers 

The massive size and scope of Internet sites makes it increasingly important to direct the 
most appropriate representative to different sections of the site. IContact displays all 
people on a site within a queue that shows the information for each Surfer laid out earlier 
(i e current page, time, etc.) As Surfers leave the site or are engaged by a NetRep, they 
are removed from the queue. We have a system that allows a flexible level of monitoring, 
of all or part of a site, by any number of NetReps. One of the unique attributes of this 
system of display is the ability to manage NetReps' time and focus their work scope. 

For example, an online brokerage firm could use three different types of NetReps on 
their site. Brokers in charge of specific clients, lower level brokers in charge of recruiting 
new business, and hourly-wage customer service agents. The iContact software makes it 
nossible to limit or open the "view" that each NetRep sees. Experienced (and expensive) 
brokers who take care of existing clients could only view the transaction pages and other 
activity behind a usemame and password login. This way they would only spend their 
time with people who have demonstrated their client status. The brokers in charge of 
recruitment could then monitor the "research" area. Here investors read through the 
company's reports and recommendations. This free research is available to non-members, 
and is a logical place to direct these NetReps. If brokers observe people spending the time 
to read through many reports, they could approach and begin a conversation with this 
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perspective client. Finally, the customer service representatives could all have a view of 
the entire site. Whether they are tasked to respond to questions, or serve as back up for 
the whole site, our system enables a company to change the view that any NetRep sees in 
order to direct and control the site. 

3) System that enable NetReps to respond to Surfers requests for assistance with 
important information about the visitor 

The iContact software makes it possible to respond to Surfers armed with a great deal of 
information about them. There are many types of software that allow a Surfer to make a 
request for a live communication. Our system's display is unique because NetReps can 
respond armed with a great deal of information about the Surfer. Our NetRep GUI first 
informs NetReps of a request for communication with an audio tone and a color change 
of that Surfer in the queue. In the seconds or minutes before the NetRep prompts the 
conversation, they have access to all the pages that the Surfer has viewed, any previous 
discussions they have had with NetReps, and any amount of data that is available about 
the Surfer requesting help. This allows them to manage their rime more efficiently for a 
variety of reasons. 

For example, during busy times, NetReps can respond immediately to the member's area, 
and choose to ignore requests from people who have been taking up NetRep' s time 
without the hope of a sale. NetReps can also approach prepared with the information that 
a Surfer is likely to request. If a Surfer requests help from a specific product page, the 
NetRep can call up all of the information about that product before they respond. While 
all other products require NetReps to respond based on time waiting or when the next 
available rep is free, iContact's visual display system allows companies to be discerning. 
In short, our monitoring system makes it possible for NetReps to spend their time with 
the most potentially fruitful Surfers. 
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Example: NetRep Assistance 
Figures 4-1 through 4-9 
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Figure 4-1 - Web visitor has a question about the iContact client, however the web 
visitor cannot find the answer on the web page. The visitor decides to ask a NetRep and 
request assistance by "clicking" the NetRep icon. 
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Figure 4-2 - The NetRep identifies the web visitor with a question. The NetRep prepares 
a message "Can I help you" and sends it to the web visitor. 
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Figure 4-3 - A conversion starts between the NetRep and web visitor. 
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Figure 4-4 - The conversation continues. 
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Fzgvre 4-5 - Information relating to the web visitor and the conversation between the 
visitor and the NetRep is captured in two ways. The iContact server automatically 
creates a database which is populated with the conversation, date, time, between the 
NetRep and the web visitor for future reference. 
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saved in a database on the iContact server. In this case the NetRep populates a Notes 
Field on the client software. A page visited history is also created of web pages that have 
been visited by the web surfer. 

The information in the database can help facilitate future sessions. For example, our web 
visitor may decide that he has enough information. The initial conversation is concluded. 
However, the web visitor realizes that he ahs another question He again requests for 
help. 
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Figure 4-7 - The conversation starts. 
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>W<? - The surfer request additional information, reminiscent to the previous 
conversation. However, the NetRep notices that the web visitor was previously captured 
and checks the databases on the server. The NetRep can review the previous 
conversation and also review the pages that that the web visitor has looked at recently. 
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Figure 4-9 - The NetRep recognizes that the web visitor had a previous question about 
the client software. He prompts the web visitor if he has any additional questions about 
the client software. 



System of communication that enables live NetReps to manage multiple 
unique communications with individual Internet visitors 

There are two distinctions that can be drawn between iContact and existing technologies. 
First chat rooms can enable communication between a human monitor (NetRep) and any 
number of Surfers who request a "chat room". There are other products that allow 
NetReps to communicate one-on-one with people requesting help. The -Contact software 
makes it possible for a NetRep to carry on any number of one-on-one communications 
with any number of Surfers. We have limited it temporarily to five concurrent 
conversations, but is an artificial limit based on our experiences with NetRep overload. 
The reality is that our NetRep GUI allows a person to balance the needs of many Surfers 
using the capabilities inherent within the system. 

When a NetRep has many people engaged simultaneously, those people all appear in a 
list The NetRep can then "click" on any Surfer to send a message to, or view the 
messages that that Surfer has sent. It is possible to use pre-set messages, as well as the 
ability to simultaneously send one message to any number of Surfers, m order to deal 
with the most visitors possible. The NetRep GUI keeps the history of all conversations 
making it possible for a NetRep to move between conversation without confusing 
individual Surfers. 
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For example, if a NetRep has four people engaged and two are asking for the same piece 
of information, the rep can look on the pre-set list and send the same message to both 
Surfers with two "clicks". 



Figures 5-1 through 5-10 
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Figure 5-1 - A NetRep is currently monitoring the site with three web visitor. The 
NetRep selects a preset message "weather" tc send to all three. 
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FigMre 5-i - The same conversation however viewed by the initial web visitor, John. 
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Figure 5-5 - Jack replies that the weather is terrible in Miami. 
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f/gwre 5-<S - The NetRep view of Jill's response. 
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- The NetRep view of Jack's situation. 
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iContact technical description 

Diagram land Diagram 1-b 

The following steps show how iContact processes a system initiation and a new page request. The solid 
lines trace the system iniciarion and the dashed lines trace the new page request. Please refer to Diagram 1 
while reviewing the following steps. 

System initiation 

(1) The visitor clicks on a treated link that calls a npage function call through iContacfs ISAPI server 
extension. The parameters for the function call are the URL of the requested -page and the visitor's id 
which defaults to the entry in the title tag of the current page. 

(2) The server extension notifies the capture server that a new visitor has requested a page. 

(3) The capture server creates a new visitor id for the visitor and returns the id to the server extension. 

(4) The server extension returns the un-captured frame set to the visitor with the visitors id imbedded in 
the title tag of the frame set. 

(5) The requested page is targeted to the content frame of the un-captured frame set. 

(6) The capture server notifies the NetRep server that a new visitor is on the site. The notification includes 
the visitors id and current page. 

(7) A new session is created in the database for the visitor which includes the visitor's current page, 
browser strings, and IP address. 

(8) The NetRep client application is notified of the new visitor. 

New page request 

(1) The visitor clicks on a treated link that calls a npage function call through iContact's ISAPI server 
extension. The parameters for the function call are the URL of the requested page and the visitor's id 
which was stored in the title tag of the current page. 

(2) The server extension notifies the capture server that a visitor has requested a new page. The 
notification includes the requested URL and the visitor's id. 

(3) The capture server returns a confirmation to the server extension. 

(4) The server extension returns the un-captured frame set to the visitor with the visitors id imbedded in 
the title tag of the frame set. 

(5) The requested page is targeted to the content frame of the un-captured frame set. 

(6) The capture server notifies the NetRep server that a visitor has requested a new page. The notification 
includes the visitors id and current page. 

(7) The page history gets updated in the database for the visitor. 

(8) The NetRep client application is notified of the page change. 

Diagram 2 

The following steps show how iContact processes a proactive engagement (NetRep initiated) and a release. 
The solid lines trace the proactive initiation and the dashed lines trace the release. Please refer to Diagram 
2 while reviewing the following steps. 



WO 99/18514 ( 



6 - 29 



PCT/US98/21272 



Proactive engagement 

(1) The NetRep initiates an engagement with a visitor. The initiation includes an introductory message to 
the visitor is sent to the NetRep server. 

( 1 A) The database is updated with the new status and introduction message. 

(2) The capture server is notified that the NetRep is engaging a visitor. The NetRep id, visitor's id, and 
initial message is sent as parameters. 

(3) The heartbeat function from the hidden frame asks the ISAPI extension if this visitor is engaged or not. 

(4) The extension asks the capture server if this visitor is engaged. 

(5) The capture server notifies the extension that this visitor is engaged. 

(6) The hidden frame receives a response that the visitor is engaged. 

(7) The hidden frame requests a full reload of the browser window. 

(8) The extension returns the captured frame set to the browser. 

(9) The requested page is targeted to the content frame of the captured frame set. 

Release 

(1) The NetRep initiates the release of the visitor. 
(1A) The database is updated with the new status. 

(2) The capture server is notified that the NetRep is releasing a visitor. The NetRep id and visitor's id are 
sent as parameters. 

(3) The heartbeat function from the hidden frame asks the ISAPr extension if this visitor is engaged or not. 

(4) The extension asks the capture server if this visitor is engaged. 

(5) The capture server notifies the extension that this visitor is not engaged. 

(6) The hidden frame receives a response that the visitor is not engaged. 

(7) The hidden frame requests a full reload of the browser window. 
(S) The extension returns the un-captured frame set to the browser. 

(9) The requested page is targeted to the content frame of the un-caprured frame set. 



Diagram 3 

The following steps show how iContact processes a reactive engagement (Visitor initiated). Please refer to 
Diagram 2 while reviewing the following steps. 

( 1 ) The Visitor initiates an engagement with a NetRep. A request_contact function call is sent to the ISAPI 
extension with a page URL and the visitor's id 

(2) The server extension returns the waiting for contact frame set to the browser 

(3) The server extension notifies the capture server that a visitor has requested contact. 

(4) The request for contact is forwarded to the NetRep server 

(5) The NetRep server notifies the NetRep clients that a visitor is requesting contact. 

(6) The NetRep initiates an engagement with a visitor. The initiation includes an introductory message to 
the visitor is sent to the NetRep server. 

(7) The database is updated with the new status and introduction message. 
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(3) The capture server is notified that the NetRep is engaging a visitor. The NetRep id, visitor's id. and 
initial message is sent as parameters. 

(9) The heartbeat function from the hidden frame asks ae ISAPI extension if this visitor is engaged or not. 

( 10) The extension asks the capture server if this visitor is engaged. 

(1 l)The capture server notifies the extension that this visitor is engaged. 

(12) The wait frame receives a response that the visitor is engaged. 

(13) The wait frame requests a full reload of the browser window. 

(14) The extension returns the captured frame set to the browser. 

(15) The requested page is targeted to the content frame of the captured frame set. 

Diagram 4 

The following steps show how iContact processes messages being sent from the NetRep to the visitor and 
from the visitor to the NetRep. The solid lines trace the visitor to the NetRep path and the dashed lines trace 
the NetRep to the visitor path. Please refer to Diagram 5 while reviewing the following steps. 

NetRep to visitor 

( 1) NetRep selects a visitor to send a message to and sends a message. 

(2) The database is updated with the new status and the text of the message. 

(3) The message is forwarded to the capture server. 

(4) The capture server updates the CNV file associated with the visitor. The CNV files contains the text of 
the message being sent. 

(5) The hidden frame asks if the visitor has received a new message. 

(6) The extension asks the capture server if a new message has been received. 

(7) The capture server notifies the server extension that the visitor has received a new message. 

(8) The hidden frame receives a response that the visitor has received a new message. 

(9) The hidden frame requests that the NetRep message frame be reloaded with the updated CNV file. 

(10) The server extension reads the CNV' file and converts it to HTML. 
(1 l)The NetRep message frame is updated. 

Visitor to NetRep 

( 1 ) The visitor send a message to the NetRep. 

(2) The message is sent to the Capture server. 

(3) The capture server updates the CNV file associated with the visitor. The CNV files contains the text of 
the message being sent. 

(4) The server extension reads the CNV file and converts it to HTML. 

(5) The Visitor message frame is updated with the new text. 

(6) The message is forwarded to the NetRep server. 

(7) The database is updated with the new status and the text of the message. 
(S) The message is sent to the NetRep 
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Diagram 5 

The following steps show how iContact can determine which NetRep is assigned to the Visitor and notify 
the NetRep that one of their clients is presently on the web site. Please refer to Diagram 5 while reviewing 
the following steps. 

(1) When a web visitor first accesses the web site they a*e registered into iContact iContact returns a 
frame set to the visitor's browser that will stay with the visitor during their visit. The frame set allows 

• iContact to track and identify the visitor. Since they have yet to login to the web site, and be identified, 
they are not displayed on any of the NetRep's workstations. 

(2) The visitor logs into the web site. Upon successfully logging into the system, a page associated with 
the visitor's NetRep, in this case M. Owens, is returned to the visitor's browser. 

(3) The returned page immediately requests a page from the iContact server. The requested page's title is 
the iContact system identifier assigned to the NetRep when their account was created, in this case 
"mowens" (actual identifier is numeric). 

(4) The page request notifies the iContact system that this visitor has requested a page with the title of 
"mowens". The page is returned to the visitor's browser and the request is passed on to the NetRep 
client applications installed on the NetRep's workstations. 

(5) The visitor's iContact assigned system identifier (25736) and the title of the page they requested 
("mowens") is sent to all the NetReps logged into the system. Each client application will determine if 
they arc allowed to monitor this individual. This is done by checking if the page title (a.k.a. NetRep's 
system identifier) is in their filter list or the visitor's identifier is in their active list. 

(6) In this case the page title is in M. Owens' filter list, so the visitor will now appear in his NetRep client 
application's Visitor List. M. Owens can also be notified by any combination of 2udible and visual 
indicators generated by the NetRep client application. 

(7) The visitor can continue surfing through the web site normally. M. Owens will not be aware of which 
page they are viewing, only that they are still on the site. 

(8) If it is determined that knowing the specific page (or section of the web site) the visitor is viewing is 
necessary then the request for the specific page (or first page of the section) will be made through 
iContact. iContact will return the requested page to the visitor's browser and pass the request on to the 
NetRep client applications. 

(9) The visitor's system assigned identifier (25736) and the title of the page they requested ("quotes") is 
sent to all the NetReps logged into the system. Each client application will determine if they are 
allowed to monitor this individual. They do this by checking if the page title (a.k.a. NetRep's system 
identifier) is in their filter list or the visitor's identifier is in their active list. 

(10) In this case the visitor's identifier is in M. Owens' active list, so the entry in M. Owens* Visitor List will 
be updated. M. Owens can also be notified by any combination of audible and visual indicators 
generated by the NetRep client application if this new page is in his page notification list. 

Diagram 6 

The following steps show how visitors can determine whether their NetRep is monitoring the site and 
available to assist them. Please refer to Diagrams 6A & 6B while review the following steps. 



Contacting their registered NetRep 

(1) The visitor decides thev want to communicate with their Netrep using iContact. They click a "Contact 
a Company Representative" link which displays a list of available NetReps. The link can be distributed 
throughout the web site. The list will contain all the NetReps registered to use iContact or it can also 
include unregistered NetReps with a list of alternative contact methods like telephone number, email, 
or an automatic call back form. 

(2) The visitor selects his/Tier NetRep from the list and clicks their name, in this case "M. Owens". 
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This sends a request to the iContact system for M. Owens. The request consists of the visitors unique 
identifier, the NetRep's identifier, and the URL of a page with the title of "mowens". 

iContact checks to see if the requested NetRep, "mowens", is logged into the system by checking the 
NetRep status list on the iContact server. 

If M. Owens is logged into the system, then a page requesting the visitor to "Please Wait for Contact" 
will be returned to the visitor's browser. Otherwise a message stating that the requested NetRep is not 
available will be returned. Alternate methods of contact can also be displayed at this time. 

If M. Owens is logged into the system, the visitor's iContact assigned system identifier (25736) and the 
title of the page they requested ("mowens*') is sent to all the NetReps logged into the system. Each 
client application will determine if they are allowed to monitor this individual. This is done by 
checking if the page title (a.k.a. NetRep's system identifier) is in their filter list or the visitor's identifier 
is in their active list. 

In this case the page title is in M. Owens' filter list and the system identifier is in his Active List. The 
visitor's entry in M. Owens' Visitor List will change its state from "Available" to "HI" designating that 
they have requested contact M. Owens can also be notified by any combination of audible and visual 
indicators generated by the NetRep client application. 

Contacting another registered NetRep 

(1) The visitor decides they want to communicate with another NetRep if theirs is not available. They 
click a "Contact a Company Representative " link which displays a list of available NetReps. The link 
can be distributed throughout the web site. Fhe lisi will contain all the NetReps registered to use 
iContact or it can also include unregistered NetReps with a list of alternative contact methods like 
telephone number, email, or an automatic call back form. 

(2) The visitor selects a NetRep from the list and clicks their name, in this case "R. Lincoln". 

(3) This sends a request to the iContact system for R. Lincoln. The request consists of the visitors unique 
identifier, the NetRep's identifier, and the URL a page with the title of "rlincoln". 

(4) iContact checks to see if the requested NetRep, "rlincoln", is logged into the system by checking the 
NetRep status list on the iContact server 

(5) If R. Lincoln is logged into the system, then a page requesting the visitor to "Please Wait for Contact" 
will be returned to the visitor's browser. Otherwise a message stating thai the requested NetRep is not 
available will be returned. Alternate methods of contact can also be displayed at this time. 

(6) If R. Lincoln is logged into the system, the visitor's iContact assigned system identifier (25736) and the 
title of the page they requested ("rlincoln") is sent to all the NetReps logged into the system. Each 
client application will detenriine if they are allowed to monitor this individual. This is done by 
checking if the page title (a.k.a. NetRep's system identifier) is in their filter list or the visitor's identifier 
is in their active list. 

(7) In this case the page title is ir. R. Lincoln's filter list, so the visitor will now appear in his NetRep client 
application's Visitor List with it's state set to "HI" designating that they have requested contact 

(8) In this case the system identifier is in M. Owens* Active List. The visitor's entry in M. Owens' Visitor 
List will change its state from "Available" to "HI" designating that they have requested contact. 



(3) 
(4) 
(5) 

(6) 
(7) 
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iContact technical description 

Diagram 7 

The following components are used in a large scale custom implementation. Please refer to Diagram 7 while reviewing the 
following steps. 

Enterprise Components 

( 1 ) ISAPI Server Extension/Filter pair - Each IS API server extension uses its own set of template files. This provides the 
ability to manage separate/distinct web sites, separate/distinct sections of a web site, and individual groups of pages as 
separate entities with their own sets of template files. Each extensions can be replaced with 2 filters. The niters will 
allow the imbedding of the unique identifier without requiring extensive page modification. 

(2) Capture Server - Manages one or many server extensions or filter pairs. Multiple capture servers allow for load 
distribution. Capture servers can run on multiple servers. 

(3) NetRep Server - Manages NetRep client applications through multiple message servers. Also distributes information to 
and from databases. 

(4) Messaging Server - Manages the distribution of messages berween NetRep client applications and the NetRep server. 
Used for load balancing. 

(5) The NetRep administration ut.iiry manages NetRep groups, preset messages, and tour guide locanons. Tour Guide 
locations are used to push pages to web visitors who have been engaged. 

(6) Database Controller - Manages access and control to the iContact and other associated databases. 

(7) NetRep client application. 

(8) Web site Administration - Used to manage the configuration of the serv er extensions; filters and the capture servers. 

Diagram 8 

The following steps show how an HTTP server developed by Contact Dynamics would be used to manage multipie separate 
and distinct web sites by an out sourced call center. The use of a custom server provides the following benefits: 

1. Minimum to no modification of the call center's client's web pages. 

2. The call center can rum off the web monitoring and direct the client's web site to funcnon normally, by not gomg 
through Contact Dynamics* server without affecting the web pages on the site. 

Please refer to Diagram 8 while reviewing the following steps. 

New page request 

(A) Visitor requests a page. The request is received by the iContact server. 

(B) The iContact server notifies the NetRep server of the page request. 

(C) The NetRep server notifies the appropriate group of NetReps. A messaging server may or may not be used. 

(D) The iContact server requests the page from the appropriate web server. The web server may be located anywhere on the 
Internet. 

(E) The web server returns the requested page to the iContact server. 

(F) The iContact server compares the creation date of the returned page with the processed page cached on its hard drive. If 
the page has been updated the server will process the page and replace the old processed page with the new page. If the 
page has not been updated the server discards the new page. 

(C) The iContact server returns the processed page to the visitor's browser. 

(H) The Visitor's browser requests the graphic files directly from the web server. 
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<I) The web server returns the graphic files. 



Diagram 9 

Each frameset returned to a Surfer contains a hidden heartbeat function as part of the content. Two heartbeat functions are 
used - one for Engaged Surfers and one for Unengaged Surfers. The logic flow of each is shown in diagrams 9-a and 9-b. 
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page 1 .html 

Regular untreated page. (Local installation) 



<KTML-> 

<TTTL£>PageWTT7LE> 

</HEAD> 
<BODY> 

<A HRHF="pagcl .hUnl" ^L-nk 1</A> <br> 
<A KRSt'« ,, page2 .htx". ">Link 2</A> <br> 



</30L*> 
</HTML> 
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pagel_icx . html 



Treated page. (Local Installation) 



<KTML> 
<HEAD> 

<TITLE*>?agel</TITLE> 

</HKAD> 
<BODY> 



<RD_DCNE0I> 

<!--<a href«"pagcl.htxl ,, >Link l</A>--> 
^script lar:guage=" JavaScript ,l > 
< ! 

document. write ("<a href - ' /bin/icx . dll ?npage?%2Fpagel%2 

EhtmlSc" + 

top. document. title + ■' target = '_top ) 
document .write ("Link V) 
document .write ( "</a>") 

// --> 
</ script > 

<noscript > , „ 

<a href = »/bin/icx.dll?npage?%2Fpagel%2Ehtrrl&-l" target-' _top 

>Link 1 < / a > 
</ nose rip r. > 
</RD_DOME01> 

<br> 



<RD_DOME01> ; 
<l--<a href »"pagc2. html ">Link 2</A>--> 
<script language= "JavaScript " > 

<! " document. write (»<a href-' /bin/1 cx.dll?apage?*2Fpagc2%2 
Ehtmlt" + 

top. document .title ■» target-' _top' >") 
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pagel_icx . html 
document .write (-Link 2" ) 
document .write ("*/s>" ) 

// --> 
</ecript=. 

<no«cript> hrofB „ /bin/icx . dU?r .page?%2Fpag e 2%2EhtmU-l» target-»_top» 

>Link 2</a> 
</noscript:> 
</RD_DONK01> 



</DODY> 
</HTML> 
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page2_icx.htrcl 



Treated page. (Redirection) 



<HTML> 
<HEAD> 

<TITLE>Pagc2</TITLE> 

</HRAD> 
<BODY> 



^r« N ^ef=-hCtp://197.16a.l.l/pa a el.hC«a->Link 1</A>- > 

<scripr. language= ,f JavaScript n > 



< 



aocumenc. write \ <^ ^ ^ _ .-.nL^^ 

hraf-Vbin/iex.dlV/np*ge?fct=P%3A%2P%2F192%2E168%aKl%2EI«^pa3«l%2Efctm. 

top. document. title + "' target-'_top' >") 
document. write ("Link i") 
document . write ( " </a > " ) 

// — > 
</scr:pt> 

<„0»cri P L> b ^ £ = B/bta/i „. dll?npage7hcC p t3A% 2F%2F192%2E168%2El%2El%2Fp 

agcl%2Kht.rait-l" 

target ~"_t op" >Lir.k Was 

</noscript> 

</RD__DONE01> 

<br> 



^r^^-h C tp://192.1«8.1.1/page2.ht«a->Link 2</A>~» 
<script Ianguage-"JavaScript"> 

top! document. title . »' target* 1 _top' >« ) 
document. write ("Link 2") 
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page2_icx.html 
document .write ( n <7*> n ) 

II -> 

<n ° aCrip <a h rcf=Vbin/icx.dll?npage ? h C tp%3A%2F%2F192%2 E l G 0%P.Ei%2EU2 ? p 

agc2%2F.html&-1 " 

target. ="_t:op" >Link 2</a> 

</noscript> 

</RD_DONK01> 

<br> 



</BODY> 
</HTMT.> 
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page2 . htTr.I 



Regular untreated page. (Redirection) 



<HTML> 
<HEAD> 

<TITLE>Page2</TITLE> 

</IIEAD> 
<BODY> 

_ HT , EF= ..>.. tr .//i9?..I68.1.l/pagei.hcn-.l«>Link 1</A> <br» 
SSSI:-SJc?;//»2.168.l.l/p^o2.h^-»Unk 2</A> <br> 



</BOD*.- 
</HTMT-> 
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EXEMPLARY CONVERSATION 
N - Representative of Site 
S - Visitor at Site 



MESSAGE TEXT 


SENDER 


TIME & DATE 


Hi, I'm Sue with Contact Dynamics. I'm here live, can I help you? 


N 


8/5/98 5:33:39 PM 


Good evening! 


N 


8/5/98 5:34:04 PM 


If you look to your right and touch compose message and begin typing in 
the box, we can talk. 


N 


8/5/98 5:34:09 PM 


Pm just trying this out as a demo. You probably get that a lot. 


S 


8/5/98 5:34:48 PM 


ShopcyberMaU, so nice of you to visit!! 


N 


3/5/98 5:35:20 PM 


Thanks. We are currendy using live chat on our web site, but we had 
someone email us to look at you guys. 


s 


3/5/98 5:36:02 PM 


Yes. I do, and it's my job, so I never mind. BTW, you have the hands 
down coolest catalog!! That's tfce consensus from our office!! 


n 


8/5/98 5:36:07 PM 


That was me. 


N 


8/5/98 5:36:16 PM 


Thanks !• 


S 


8/5/98 5:36:25 PM 


No live chat, this is a powerful sales tool and lead generator. 


N 


8/5/98 5:36:36 PM 


There are two models of Contact. Inbound and Outbound. I use both at 
the same time. 


N 


8/5/98 5:38:53 PM 


Outbound allows you to see the surfers on the si's, where they are. and 
how long they stay. With Outbound you can initiate a conversation with 
any surfer at any time. This is how I saw you enter the site and how I 
captured you!! It is unique to us alone. 


N 


8/5/98 5:39:17 PM 


How are you saying that? How is this different from Interactive Express? 


S 


8/5/98 5:39:21 PM 


70% of all people who engage your commerce server do not finish the 
transaction. Our software can make a difference. 


N 


8/5/98 5:39:48 PM 
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MESSAGE TEXT 


5>bNUbK 


TIMC B* T\ A TC 
1 1Mb oL UA 1 t 


Okay, but how is this different from your competitor XYZ's 




8/5/98 5:40: Z5 rM 


They can't engage a surfer. They have to wait for a request for 
assistance. We don't wait!! 


N 


8/5/98 5:40:27 PM 


Oh, I see, When would you feel it necessary to interrupt a shopper? 


S 


8/5/98 5:41:01 PM 


Let rne show you our interface. Click direcdy on the next message I send 
you. 


N 


8/5/98 5:41:07 PM 


Don't* think of it as interrupring, you're assisting, just like a high line 
department store would. 


N 


8/5/98 5:41 :49 PM 


Plus, we don't have to download any junk into your surfers machines 


N 


8/5/98 5:43:12 PM 


No downloads, applets, cookies or plug ins 


N 


8/5/98 5:43:28 PM 


Contact is a server extension browser driven. It uses NT. We can talk 
with any visitor that has a browser that was written within the last two 
years. 


n 


HO/yo 5:4 J .JO rM 


I can conduct five individual conversations at one time on my station. 
Although I can actually see thirty surfers in the queue 


N 


8/5/98 5:43:53 PM 


How do you contact them? Does a window just open up in the middle of 
their visit? How can you tell who they arc? 


S 


8/5/98 5:44:11 PM 


Just like what you are looking at right now!! But. it can be customized 
however you would like. 


N 


8/5/98 5:44:42 PM 


1 can actually see them on my side. Want to see? 


N 


8/5/98 5:45:01 PM 


Sure 


S 


8/5/98 5:45:17 PM 


I once them to know who they are. 


N 


8/5/98 5:45:22 PM 


Go to Contact Inbound or you can just click on my message to you and it 
will take you there. 


N 


8/5/98 5:45:57 PM 


<a href==7out-zoom.htrn" target "content" > Click here for a Netrep 
screen shot <a> 


N 


8/5/98 5:46:14 PM 


You haven't moved yet That's the other thing. I can see where the surfer 
goes and have a history of their last ten pages that they visited. 


n 


8/5/98 5:48:03 PM 


You've got it now, and you can zoom on that picture to get a better look. 


N 


8/5/98 5:57:16 PM 


Where do you see who I am? 


S 


8/5/98 5:58:07 PM 


Lower left arc the surfers, and your IP number can be traced through a 
simple tracing program. I can get name and address of the company you 
are with from a static server 


N 


8/5/98 5:59:06 PM 


AOL you just get numbers, can't ttace those. 


tf 


8/5/98 5:59:20 PM 


Figures - 


S 


8/5/98 5:59:38 PM 


The captured surfers have unique identifier numbers between die two 
windows on the bottom 


N 


8/5/98 5:59:56 PM 


So. Contact Dynamics is the surfer here? 


S 


8/5/98 5:59:58 PM 


Wow - 1 am impressed!! 


N 


8/5/98 6:00:26 PM 


You are the first person that noticed 


N 


8/5/98 6:00:39 PM 


Don't get too excited, that's my job. 


S 


8/5/98 6:00:47 PM 
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MCCCAHP TPYT 
JVIEOOAI-JC 1 CA 1 


SENDER 


TIME & DATE 




Maybe I'm the 1st person who cares. 




8/5/98 6 01 07 PM 


5 


Mine too, but it's also a lot of other peoples jobs that visit me, no one has 
got it yet. You must be a woman!! Please tell me I'm right!! 




8/5/98 6 01*34 PM 




Yes, you must be too. 


N 


8/5/98 6:01:57 PM 




Hooray!! 


N 


8/5/98 6:01:26 PM 




Hear us ROAR! 


S 


8/5/98 6:02:46 PM 


10 


It's fanny how this works, but I can even tell if a person is having a bad 
day on this. It's very intimate. The surfers get comfortable very quickly. 
The response was far greater than we ever dreamed possible. 


N 


8/5/98 6:03:31 PM 




Neat Do you have an information packet you can send to me? You have 
my address.. .ray name is Jane Doe. Director of commerce. Please 
advise. 


« 
o 


8/5/98 6:04:39 PM 


15 


Yes, Jane. I do. Can you supply me with your address. I'll get it out in 
a flash!! 


N 


8/j/yo 0:U3:zi rM 




Maybe you would even like an cval demo, huh? 


N 


8/5/98 6:05:42 PM 




I thought my address came up for you. 


S 


8/5/yo Q.vO.lZ rM 




Yep. 


S 


8/5/98 6:06:23 PM 


20 


Jane. I'm sorry. I did have that address. 


IN 


O/J/VO O.U/.1U iffl 




Well, I'll send you the info and if you wouldn't mind a call from a rep, I 
can get you the eval. 


N 


8/5/98 6:07:39 PM 


25 


Okay, I'm going to go now. Phone number is I J 1-555-6789. I'll be out 
of town tomorrow and Friday and out of the office next week Tues. and 
Wed, and possibly Thur and Friday. Busy schedule! Later! 


s 


8/5/98 6:08:36 PM 




Sarah, I'm so glad you stopped by. You've been a delight! 


N 


8/5/98 6:09:33 PM 




Thanks! 


S 


8/5/98 6:09:54 PM 




FYI-Our granddaughter's name is Jane. So, we have a kinship already!! 


N 


8/5/98 6:10:12 PM 










30 









35 
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From the foregoing, it will be observed that numerous variations 
and modifications may be effected without departing from the spirit and scope 
of the invention. It is to be understood that no limitation with respect to the 
5 specific apparatus illustrated herein is intended or should be inferred. It is, of 
course, intended to cover by the appended claims all such modifications as fall 
within the scope of the claims. 
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What is Claimed : 

1 . A method of using a communications network comprising: 
detecting the presence of a particular visitor at a particular 

page of a web site; 

5 transmitting an indicator to a selected display whereupon 

transmission of a return message to be presented to that visitor can be initiated; 
and 

transmitting the return message to that visitor for viewing. 

2. A method as in claim 1 which includes tracking the 
10 progress of the visitor through the web site and building a list thereof. 

3. A method as in claim 2 which includes transferring a 
response from the visitor to the display. 

4. A method as in clam 3 which includes transferring a 
responsive reply back to the visitor substantially on a real-time basis. 

15 5. A. method as in claim 4 including enabling the visitor to 

carry out a commercial transaction. 

6. A method as in claim 4 including facilitating the carrying 
out of an interactive conversation. 

7. A method as in claim 2 which includes displaying a list 
20 of pages presented to a visitor over a period of time. 

8. A method as in claim 7 wherein the list of pages is 

displayed at a displaced site. 

9. A method as in claim 8 which includes presenting to the 
visitor an indicator whereby the visitor, when viewing a selected page, can 

25 initiate a bi-directional conversation with the displaced site. 

10. A method of communicating with an individual who has 
logged onto a communication network comprising: 

presenting at least a part of an information sequence, 
displayable in part, and including one or more pages that may be displayed at 
30 various times in response to commands entered by the individual; 

detecting when the individual is viewing a page; 
tracking the progress of the individual through a plurality 
of pages which are in part presentable graphically; 
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storing the tracking information; 

transmitting, from another site, a selected communication 
to be presented to the individual to facilitate interaction with the page being 
displayed for the individual; 

enabling the individual to form a responsive message; and 

transmitting the responsive message to the another site for 
reviewing and in real-time, carrying out an interactive information interchange 
between the individual and the another site. 

11. A method of facilitating interactive communications using 

a network comprising: 

selecting at least one page containing displayable 

information and commands for implementing a display; 

incorporating additional commands, which when the page 
is to be displayed at a requesting site, provide information to another site; 

displaying the selected page in response to a user's 

request; and 

initiating a bi-directional information interchange, on the 
page being displayed, using the provided information. 

12. A method as in claim 11 wherein the initiating step 
includes opening a dialog box on the page being displayed. 

13. A method as in claim 12 wherein a message can be 

entered into the dialog box. 

14. A method as in claim 13 wherein the message can be 

transmitted to and displayed at another site. 

15. A method as in claim 14 which includes building a list at 
the another site indicative of the pages displayed at the requesting site. 

16. An information sequence, in part displayable for a viewer, 

comprising: 

a text sequence to be displayed; 

a sequence of display controlling commands combined 

with the displayable text; and 

a sequence of tracking commands, combined with the 
displayable text whereby information pertaining to text being presented to a 



12 



WO 99/18514 ( ( PCT/US98/21272 

viewer can be presented, substantially in real-time, at a displaced location for 
tracking the text being presented to the viewer. 

17. A sequence as in claim 16 wherein the text sequence is 
organized as a plurality of linked pages and wherein at least some of the pages 
include frame based commands for tracking. 

18. A sequence as in claim 16 which includes, as commands, 

hypertext mark-up tags. 

19. A sequence as in claim 18 which includes as tracking 
commands, hypertext framing tags. 

20. A sequence as in claim 17 wherein the pages include, as 
commands, hypertext mark up tags and wherein at least some of the pages 
comprise hypertext frame tags. 

21. A multi-processor communication system comprising: 
a visitor client; 

a visitor server, coupled at least intermittently to the visitor client 
for transferring information therebetween whereby a visitor using the visitor 
client and the visitor server can request a selected file, specified by the visitor; 

a monitoring client; 

a monitoring server, coupled at least intermittently to the 
monitoring client, for transferring information therebetween wherein the servers 
can communicate via a common network, whereby a representative using the 
monitoring client and the monitoring server can initiate an interactive real-time 
information interchange with the visitor and wherein the visitor can reply 
thereto on a one-on-one basis. 

22. A system as in claim 21 wherein the visitor client 
includes, at least in part, a browser to facilitate a display of the selected file. 

23. A system as in claim 22 wherein the browser is capable 
of interpreting HTML-type tags in the file to facilitate display thereof. 

24. A system as in claim 23 wherein the monitoring server 
receives information indicative of the progress of the visitor in reviewing the 
displayed file. 
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25. A system as in claim 24 wherein the monitoring server 
includes a control program for forwarding to the monitoring client the progress 
indicating received information. 

26. A method for using a computer to enable a web site 
representative to observe in real-time a web site usage profile of any one of a 
plurality of web site visitors and proactively to engage the visitor in a one-to- 
one, real-time conversation, comprising: 

recording information about each visitor's usage of the respective 
web site including a list of the web pages the visitor has viewed and the amount 
of time spent on each, a unique visitor's address, a status indicator showing 
whether the visitor has been previously engaged by another representative, the 
total time the visitor has spent on the web site, and a unique identifier for each 
visitor; 

displaying to a group of representatives the above information for 
the visitors to all or a selected portion of the web site in real-time; 

enabling any one of a plurality of representatives to select any 
one of a plurality of visitors to engage in a private one-to-one conversation; and 

proactively engaging the visitor so chosen in a one-to-one 
conversation without any action on the visitor's part. 

27. A method as in claim 26 which includes: 

enabling a visitor to request a conversation with a representative; 
enabling one representative to engage in one-to-one conversations 
with a number of visitors simultaneously; 

enabling the representative to send messages and other content 

to the visitor; 

enabling the visitor to receive messages and other content from 
the representative; 

enabling the visitor to send messages and other content to the 

representative; 

enabling the representative to receive messages and other content 

from the visitor; and 

enabling the representative to proactively terminate the 

conversation with any engaged visitor. 
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28. A. method as in claim 26 which includes: 

enabling the visitor to terminate the conversation with the 

representative. 

29. A method as in claim 26 which includes: 

recording all or part of the recorded information into a database 
for future use and analysis. 

30. A method as in claim 26 which includes displaying for a 
visitor a two-part graphical display with the representative's comments at one 
location and the visitor's comments adjacent thereto. 

31. An apparatus enabling a web site representative to observe 
a real-time web site usage profile of any one of a plurality of web site visitors 
and proactively engage a selected visitor in a one-to-one, real-time 
conversation, comprising: 

a storage device; and 

a processor connected to the storage device wherein the storage 
device includes a program for controlling the processor; and 

wherein the processor interacts with the program to record 
information about each web site visitor's usage of the web site including at least 
a list of the web pages the visitor has viewed and the amount of time spent on 
each, a unique visitor's address, a status indicator showing whether the visitor 
has been previously engaged by another representative, the total time the visitor 
has spent on the web site, and a unique identifier for each visitor. 

32. An apparatus as in claim 31 wherein: 

the program displays to a group of representatives the 
information for the visitors to all or a selected portion of the web site in real 
time including instructions to allow any one of a plurality of representatives to 
select any one of a plurality of visitors to engage in a private one-to-one 
conversation and to proactively engage the visitor so chosen in a one-to-one 
conversation without any action by the visitor. 

33. An apparatus as in claim 31 which includes: 
commands to enable a visitor to request a conversation with a 

representative and to enable one representative to engage in one-to-one 
conversations with a number of visitors simultaneously; 
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enable the representative to send massages and other content to 

the visitor; 

enable the visitor to receive messages and other content from the 

representative; 

5 enable the visitor to send messages and other content to the 

representative; 

enable the representative to receive messages and other content 

from the visitor; 

enable the representative to proactively terminate the conversation 

10 with any engaged visitor; 

optionally enable the visitor to terminate the conversation with 

a representative, and 

optionally record all or part of the above information into a 

database for future use and analysis. 
15 34. An apparatus as in claim 32 which includes: 

a display device displaying information in real time including, but 
not limited to, a list of the web pages the visitor has viewed and the amount of 
time spent on each, a status indicator showing whether the visitor has been 
previously engaged by another representative or not, the total time the visitor 
20 has spent on the web site, and a unique identifier for each visitor. 

35. An apparatus as in claim 31, wherein: 
the storage device optionally store a record of all or part of the 
information regarding the user's web site usage program recorded by the 
apparatus. 

25 36. A method for using a computer to observe a real-time web 

site usage profile of any one of a plurality of web site visitors, to compare that 
profile with a number of predefined web usage profiles which are associated 
with lists of actions to be performed upon a pattern, to determine if the visitor's 
usage profile matches any one of these predefined profiles, and to automatically 
30 perform the action associated with the matched usage profiles, comprising: 

storing a number of predefined web site usage profiles; 
storing and associating a list of actions with each predefined 

usage pattern; 
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recording information about each web site visitor's usage of the 
web site including, but not limited to, a list of web pages the visitor has viewed 
and the amount of time spent on each, the visitor's address, a status indicator 
showing whether the visitor has been previously engaged by another 
representative, the total time the visitor has spent on the web site, and a unique 
identifier for each visitor; 

comparing the above information with each predefined usage 

profiles and their associated actions; and 

executing the associated action list upon a successful match 

between the visitor's usage pattern and the predefined usage pattern. 

37. The method of claim 36 further comprising: 

inputting into the computer a number of descriptions of a web 

site usage pattern; 

inputting into the computer a number of lists of actions to be 

performed by the computer; 

associating each usage pattern description v/ith at least one list 
of actions to be performed by the computer; and 

editing and deleting the descriptions of web site usage patterns, 
the lists of actions, and their associations. 

38. An apparatus for observing a real-time web site 
usage profile of any one of a plurality of web site visitors, to compare that 
profile with a number of predefined web usage profiles which are associated 
with lists of actions, to determine if the visitor's usage profile matches any of 
these predefined profiles, and to automatically perform the action associated 
with the matched usage profiles; comprising: 

a storage device; and 

a processor connected to the storage device; 
the storage device storing: 
a number of predefined web site usage patterns; 
a list of actions associated with each predefined usage pattern; 
a program for controlling the processor; and 
wherein the processor is operative with the program to record 
information about each web site visitor's usage of the web site including, some 
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or all of a list of the web pages the visitor has viewed and the amount of time 
spent on each, a status indicator showing whether the visitor has been 
previously engaged by another representative or not, the total time the visitor 
has spent on the web site, and a unique identifier for each visitor and wherein 
the program includes commands for comparing the above information with each 
predefined usage profile and executing the associated action list upon a 
successful match between the visitor's usage pattern and the predefined usage 
pattern. 

39. The apparatus of claim 38, in which the processor is 
further operative with the program to: 

input a number of descriptions of a web site usage pattern; 
input a number of lists of actions to be performed by the 

computer; 

associate each usage pattern description with at least one list of 
actions to be performed by the processor; and 

editing and deleting the descriptions of web site usage patterns, 
the lists of actions, and their associations. 

40. A method of analyzing visitor movements through a 
plurality of related files comprising: 

tracking viewing paths of a plurality of viewers of the 
files; analyzing the tracking information and identifying selected file sequences 
which exhibit a greater incidence of viewing paths than other sequences. 

41. A method as in claim 40 wherein the tracking step is 

carried out in real time. 

42. A method as in claim 41 wherein the tracking information 

is stored. 

43. A method as in claim 42 wherein the analyzing step is 
carried out relative to the stored tracking information. 

44. A method of identifying a visitor at a web site comprising: 
detecting the presence of an individual visitor at the site; 
determining the visitor's IP address; and 

assigning a unique identifier to the visitor in addition to 
the visitor's IP address. 
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Surfer requests a web 
page 



Diagram 1-b: 
Flowchart of Surfer 
requesting a new web 
site page (npage). 



Assign a unique ID 
and create a surfer 
account 



Set Surfer state = 


YES 


NOT_ENGAGED 








YES 








* 





! Update Netrep display 
j and 
Return Noncaptured 
frameset 




Update Netrep display : 
and 

Return Captured j 
frameset 
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Surfer sends captured 
heartbeat 



Diagram 9-a: 
Flowchart of Captured 
Heartbeat (cpull) 




Set Surfer state = 
NOT ENGAGED 



Reset Lost-Surfer time 
out period 
and 

Return captured 
heartbeat 



Update Netrep display 

and return 
Noncaptured frameset 
(containing uncaptured 
heartbeat) 



Surfer sends 
uncaptured heartbeat 



Diagram 9-b: 
Flowchart of Uncaptured 
Heartbeat (upull) 




Set Surfer state ; 
ENGAGED 



Reset Lost-Surfer time 
out period 
and 

Return uncaptured 
heartbeat 



Update Netrep display 

and return 
Captured frameset 
(containing captured 

heartbeat) 
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